# REHDESIGN

# IDE-Interface

Manual

#### 1. Introduction

The REHDESIGN IDE-Interface is a peripheral device in eurocard format, for use in ECB-bus based microcomputer systems. It contains an IDE hardisk interface (for which it is named), plus an active bus terminator for all ECB-bus signals, a parallel (Centronics) printer port, and circuitry for Reset and NMI pushbut tons. It has been designed as a supplement for single-board computers such as the REHDESIGN CPU280, but it can be used in all ECB-bus systems.

#### 2. Circuit

The implementation of bus termination, centronics-interface, and Reset/NMI is simple, not to say primitive. However, the IDE-harddisk interface requires some hardware effort, unless one wants to deal with extra difficulties in the software. Harddisks with an IDE-interface transmit data in words of 16 bits, while accesses from the ECB-bus master can only transfer bytes (8 bits). Therefore each 16-bit data access has to be split into two 8-bit transactions. The simplest solution would be to separate the data on two I/O addresses, which allows the interface to identify the two halfwords by their address. This technique would not allow DMA transfers though, since DMA controllers can not alternate between two ports to access the data. This board uses another method: The splitting is done by the order of the byte accesses; that means that reading or writing to the just one I/O address alternates between odd and even half-words. This is done by toggling a flip-flop for each data access. Since all the control registers are only 8 bits wide, they don't use the toggling logic, only the data register does. Resetting the flip-flop during each access to a control register ensures that it is in the correct state when beginning a data transfer.

Nearly all of the address decoding and word-splitting is implemented using a single GAL. The remaining functions are done in simple TTL-chips. That keeps the circuit simple and the cost low.

There is a critical detail in the timing of the ECB-bus: When writing data to peripherals, the data lines become invalid approximately at the same time as when the the strobe signals change state. The (rather large) data hold time required by the IDE interface creates a real problem in this situation. To fix this problem, the IDE interface generates a synchronous write pulse using IC10 and IC11. It occurs about in the middle of the bus transaction, and ensures that the data lines stay valid long enough after the write pulse. This write pulse is used both to control the IDE harddisk and the Centronics interface. A similar pulse makes sure the upper half-word is correctly latched when reading data.

Another weak point of IDE-harddisks is their rather unstable interface behaviour. They are very sensitive to short pulses (spikes) on the address lines, even if these spikes are sufficiently far away from valid accesses. In the ECB-system used to develop this board such spikes were generated on the address lines A0 and A2 when /IORQ goes active and enables the data bus (which is physically located right next to A0 and A2). This completely confused the IDE harddisk. It seems that the only really safe solution is to add time constants, implemented here with R16, R17, C5 and C6. The spikes are attenuated by these RC-lowpass filters, and don't make it past the next input buffer. The delay caused by the lowpass filters doesn't cause any harm.

#### 3. Parts list

| IC1<br>IC2,IC7,IC9,IC13<br>IC3<br>IC4,IC11<br>IC5<br>IC6<br>IC8,IC12<br>IC10<br>IC14<br>IC15<br>IC16      | GAL 20 V 8, 25 ns or faster 74 HCT 244 74 ACT 245 (or ALS) 74 HCT 32 74 HCT 139 74 HCT 373 74 HCT 374 74 HCT 74 74 HCT 72 74 HCT 123 74 HCT 123 74 HCT 100 TLC 271 |
|-----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| T1<br>T2<br>T3,T4<br>D1,D2,D3,D4,D5                                                                       | BD 433<br>BD 434<br>BC 547 or similar<br>LED 3mm red or similar                                                                                                    |
| C1,C2<br>C3,C4<br>C5,C6<br>CK1-16,CK19-20<br>CK17,CK18                                                    | 2 n 2 cer. LS 5<br>1 μ Ta. LS 2.5<br>47 p cer. LS 5<br>_18x 100 n cer. LS 5<br>10 μ Ta. LS 2.5                                                                     |
| R1,R11,R12<br>R2,R3<br>R4,R5<br>R6,R7,R8,R9<br>R10,R13<br>R14,R15<br>R16,R17<br>P1<br>RN1<br>RN2<br>RN3-6 | 330 R 47 k 1 M for termination of special signals 1 k 4 k 7 470 R 50 k (trimpot 0.400" flat) RSIL 8x 10k RSIL 4x 10k 4x RSIL 4x, for term. (220-330 R)             |
| CN1 ECB CN2 IDE CN3 CENTR. CN3a CENTR. J1 RESET J2 PDIAG J3 INIT                                          | DIN-41612-C conn., 64 pins, rows ac<br>Header 40-pin<br>DB 25 S rightangle<br>Header 26-pin (Option, CN3 or CN3a)<br>Header 1x3<br>Header 1x2<br>Header 1x2        |

### 4. Adjustment

The connector for the Centronics interface can either be a rightangle D-sub connector (for use in crates with front panels) or a header (to extend the port to any desired location).

Before using the board, the termination voltage has to be adjusted, and a few jumpers have to be selected.

A voltage of about 2.7V for the active termination has been found to be a good choice. It provides sufficient load (and therefore damping) both for high and for low signal levels. The recommended value for the resistors is in the range of 220 to 330 Ohm (should be about the same as the impedance of the bus backplane). If the CPU280 is used as the bus master, the individual resistors R6 through R9 usually don't have to be used at all.

Jumper J1 (Reset) is normally in the "upper" position, so that the signal "Reset-Out" from the bus is routed to the harddisk. Jumper J2 is usually left open (used for testing). Jumper J3 is usually left open too (who would want to reset the printer whenever the CPU is reset?).

## 5. GAL programming

All the central control functions of the IDE-interface are implemented in a GAL (IC1), which is a GAL 20V8.

TITLE

IDE/CENTRONICS INTERFACE GAL ICT

AUTHOR COMPANY DATE 08.05.1992

TILMANN REH REHDESIGN

; All accesses to the harddisk occur with LH = High. This means this signal

; has the opposite meaning when reading, as opposed to writing. ; For the flist read access to really address the disk, one has to read the ; data register once (set LH) before the actual data transfer.

#### CHIP IDE PALCEZOVE

CK A7 A4 A5 IORQ A6 WRP A0 A1 A2 A3 GND OE M1 CLK LH CS0 RD16 SEL WRLO WR16 RDHI RD VCC

; Change the base address (BASE) only here! The lower nibble of the addresses; is partially determined by hardware, and not changeable.

STRING BASE '(A7 \* /A6 \* /A5 \* /A4)' STRING PARSEL '(BASE \* /A3 \* A2 \* /A1 \* A0)\*
STRING CS1ADR '(BASE \* /A3 \* A2 \* A1)\*
STRING DATADR '(BASE \* A3 \* /A2 \* A1)\*
STRING THRADR '(BASE \* A3 \* (A2 \* A1 \* A0))\*
STRING THRADR '(CS1ADR + DATADR + TFRADR)\*
STRING IDEADR '(CS1ADR + DATADR + TFRADR)\* STRING IO '(/IORQ ' MI)' : I/O-Request

; Centronics Adr. x5 ; CS1 Adr. x6.x7 ; CS0/Data Adr. x8 ; CS0/Task Adr. x9.xF ; all IDE addresses

EQUATIONS = TFRADR + DATADR \* LH ; Task File access ; Data Write MSB / Read LSB /CSO /SEL = (PARSEL + IDEADR) \* M1 ; Board access (address only) = (DATADR + TFRADR) \* IC ; LH-Clock: Data & Task File := /LH \* /TFRADR ; FlipFlop: LSB/MSB Toggie ; Reset when task file access WRLO = DATADR ' IO ' /WRP ' /LH + (TFRADR + CS1ADR) ' IO ' /WRP Data LSB write to latch : Transparent for all others WR16 = IDEADR 10 1RD : MSB and latched LSB to IDE /RD16 = DATADR \* 10 \* /RD \* : Data LSB read, MSB latch + (TFRADR + CS I ADR) \* IQ \* /RD ; all others transparent /RDHI = DATADR \* IO \* /RD \* /LH ; Data MSB read from Latch

# 6. Pinout ECB-bus

| a        | Nr               | c       |
|----------|------------------|---------|
| +5V      | 1                | +5V     |
| D5       | 2                | D0      |
| D6       | 2<br>3<br>4<br>5 | D7      |
| D3       | 4                | D2      |
| D4       | 5                | A0      |
| A2       | 6                | A3      |
| A4       | 7.               | A1      |
| A5       | 8                | A8      |
| A6       | 9                | A7      |
| /WAIT    | 10               |         |
| /BUSREO  | 11               | IEI     |
| •        | 12               |         |
| (+12 V)  | 13               |         |
| ,        | 14               | D1      |
| -5 V     | 15               | -12 V   |
| 2xCLK    | 16               | IEO     |
|          | 17               | A11     |
| A14      | 18               | A10     |
| +12 V    | 19               |         |
| /M1      | 20               | /NMI    |
| •        | 21               | /INT    |
|          | 22               | /WR     |
|          | 23               | •       |
|          | 24               | /RD     |
|          | 25               | (/HALT) |
| •        | 26               | /ŘESOUT |
| /IORO    | 27               | A12     |
| /RFSĤ    | 28               | A15     |
| A13      | 29               | CLK     |
| A9       | 30               | /MRQ    |
| (/BUSAK) | 31               | /RESIN  |
| GND      | 32               | GND     |

#### 7. Software

The IDE interface occupies in total 11 addresses in the I/O address space of the ECB bus. The base address may be chosen freely in steps of 16 by appropriate GAL programming, while the lower 4 bits of the addresses must not be changed. Always the addresses x5h to xFh are used, with the standard GAL contents this means the addresses 85h to 8Fh. The particular ports have the following addresses (assuming base address 80h):

#### Centronics-Port

Writing data to this port sends the written byte to the printer port (8 bits), while reading this port returns the actual interface state. The individual bits are defined as follows:

Printer: Acknowledge Printer: Paper Empty Bit 0 Bit 1 Printer: Error Bit 2

Bit 3 Printer: Select

Bit 4 IDE Harddisk: Interrupt Request

Bit 5 Printer: Busy

Interface: Strobe Delay Bit 6 Interface: Composed Busy Bit 7

When Polling the interface state before sending characters to the printer, bit 7 (composed busy) is to be used (0 = interface ready).

#### 86h IDE-Harddisk Digital Output Register 87h IDE-Harddisk Alternate Status Register

These two registers are not surely existing or defined identical in different drives of different manufacturers. Before using them, the manual of the harddisk must be read! (In PC/AT's, these registers normally occupy the addresses 3F6h and 3F7h.)

88h IDE-Harddisk Data Register 89h IDE-Harddisk Error Register 8Ah **IDE-Harddisk Sector Count** IDE-Harddisk Sector Number 8Bh IDE-Harddisk Cylinder Low IDE-Harddisk Cylinder High 8Ch 8Dh IDE-Harddisk Drive and Head 8Eh 8Fh IDE-Harddisk Command/Status Register

> These eight registers are the working registers for accessing the IDE harddisk. The contents of these registers are normally identical even with different drive types of different manufacturers (according to the so-called industry standard). However, there might me slight differences about some single bits and the usable command codes. So, reading of the individual harddisk manual is strongly recommended, too. (In PC/AT's, these registers occupy the addresses 1F0h to 1F7h.)

This manual was translated by Ralph Becker.



